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JlfrE"r— * \fy b<D«( y — 7£tiX\<^j:is^ b V 

>-<D*:ti*:tiWy b<DT Ki/^^L, -f>-*-y 

-y^frfc^ — ^ fy hCO-^ h y ^COtfy NcO-^*V£* 

itftE^fteh^r K^cffiot, Bfjf5^>-^-y-y 
stLfc^-^bv b<D^ti^fti<D^y htmisftifettR 

t?3£-<#x. I r (k) = [ar k+f 
Wafe^W*. I c (l) = [ac k-h f 



i»*3S2] wet Ku^oa#{k3fts, mm^-wy 
hco-r — y — y^nti^i^ h y ? 

fbtipii:*ft-mtTStts»*:JSi jcEtto^-^ t*y 

yh-i — H^y^^S-fr Strife, 
^f-^fs/h^ J^Tco^: (i) fc«oTfTri:«c 



c (i )^ij-r ^7**9* i o-tfn-e*i/^ia»T*fe«9, i 

*i 1 -Nc WfiEJfe-Cfc 9 , Ic(l )ttyiJ>f isfyf* 1 
wf-^tj/hSrSU actttSfct*^ fr(k)tt 
^v&tzteft^ >"ry? Xk<Dm%tX&>K) ^ modNrfcS 
J;lKnodNe li^i/anNr *5 J: U^t ^ p Nc Wffi* 

* ri> 6 Ml £ ft £ ft 5 W*« l rt> p> WjRjI 3 co v >-ftt/)Mc: 

IS^COX— ^ \fy h • h^TBlfMcO^— * fc^y H • U- 

- blz-?y^>r&1tZ>jfW: 0 
[SS*^5] gffEf c ( 1 )*K fc(l)=ral+[Nr 
+ l ]mod 2 -Cfc 9 , mlifi[»-e«)S»*:«4^EIKO'7 f 

— * try h . u— b&mm^—? tr h • mc-^ 

[flt*K6] tfrEmri*, *5i-tNr /Nc f£*?L^i»# 
JS5Kf2ffico^-* f y h • u~ hSrgffScOx-^try $640 

tTM-<#^ I r (k) = [or k + f 

zm^mz- i 



( l )]modNr 
(k)]modNc 

3t (1) 

[B#«7]|fEfr(k)^ fr(k)=2k+[Nc 

+ 1 ]mod 2 "Cfc£fS*«4 6 CEtOr- ^ 

fcf 3/ h • 1^— b&mmcDy"—? \f y b * U~ hC^yf 

[19*35 8] mlfea r Nr /I0g2 (I0g2 (Nr )) <t 

X— ^ t^h- b^mW.CD'T — ? tf 5/ h • I/— 

[«*3S9] W**i**5>»*JS8<^v^i"tL3&^E*<iO 
^ cotT jo J: WlZ&^Wx-Z - <b ^r-g-trx- ^ y b£ 

a^tco^: (2) KoTtr:'t 

[»2] 



w^T\ I r (k)fitr^ yry kco^—^ tfy 

fc(l xfy^ 1 co-tf pf4i>Hat'fc!3, 

l l±i-Nc co^©:T*fc^, led )I^H>f^^ 
1 cox-i? fcfy h^r^L, oc ttBE«-efe«3, fr(k) 
fiif D^fcHtT-f V^3/^^kcO^T^«9, modNr 



( I )]modNr 
( I ) = [a e k + f r (k)]modNc 

* (2) 

&Zti*:ti&LX*$*) , 
IB*3Sl 1] WtEmd*, fcUNr/Nc tC^L^IS 

*isi o^Emo^-^tfy h^^-y-m* 

50 & 
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im&mi 2] ffrlEa r Nr /I0g2 (l0g'2 (Nr )) 

mis®^-* try h&'f^-y 

[8S*B1 31 »*Sl (K 1 1 £fcf*l 2fc:8att<Z>;*' 

^-y-yiti/-h-77fym*i£^ot, be 

[0 0 0 1 1 
[0002] 

(FEC) $:SfflLtf-^Wy^-y-fy^ (in 
ter leaving) SrIfftSli:l:J: r^is*— y— tf 
>^ (de inter leaving) co^tc, ^ — ^ffc^-frT^ 

12, -tcoj: 9*-r y — ev^tt, f-^D.^ 
fk) tt, ^^-y-fy^M-cA^f-^jj^^ 



. 2001-57521 

</ 

ZtlXZX^Za 

[0 0 0 3] l^*5S3ttttWCDMA (f?-5§- 

10ms <7)S|j»7 U—ASPjgg^KtC^i-S^P 

v * - y - x <& & g t -r 5 *sn ii ft v- * x a a* m& & ti 

V (puncturing : W 9 &X) t.tztefc'& (repetition) 
[0 0 0 4] 

>/ * te&m * ixfc tr * h m sek^s -e # -5 it ± # 

[0 0 0 5] 1 9 9 9^3^ 1 9 0 tCWen Tongfdl{-J: 9 

y — y-fr&jjfe (Data Inter leaver And Metho 
d Of Inter leaving Data) j irW-rs^-^^WffffflR 
(7 7 >f^#f : 10378R0) tt, ±ISfC#^ Lfc^* 

/u • ^^^-y-tfv^srgw-rsotc^ijtcffiffi-rs 

C k Z^r-ffr-f y — <fct*f* 

— ^ • v^-y — /<jcov>r8sa?Lri^So 

ii, t<D£ it£?-**/u • v^— y — t'^^co^— 

* ico^rM^o^J s -cffiffl-rs r k <dxz z^*)!; 

<d >r v ^ - y - y s ti ^ iz n l x t> Sffl r s r t 
^yu • ^fy^-y»t'y^7^y >5r— >a yc^l^r 

[0 0 0 6] 

-5fe^O#a] :^^<^ 1 OtDftlJffi^ 
<t6<b, ^46^:^ibnfc-r>'^-y-t:'^ 
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5 

— mrlS^ — * ¥y b<D^ — D — ^tiT^ft 

ticntry v<dt ki/^^mu striae v*— y — 7£ 

fitzzr>-? \fy V(D^ V V ?X\C&tfZ> \fy b<D*tl*f 
Kl'^MoT, StrlE-f — y-^^tb/h^-^ \fy 

[0007] 7K^©iW, mife^-^ try ho 
-Y >?—v—7£thx\<^^ h y ^*^<b-r y 
-y&titzr-? try hz*tj&-tz>T b-isxcon^ikt 

* 9 5 So rtttt. NrtT*5«tr^N c yijco^ hy ^ 

So 

[0 0 0 8] 
[*3] 

X. Ir(k)=[ork+fc(l )]m0CJNr 

?|J&-<#X. Ic(l ) = [ac k + f r (k)]modNc 

[0009] ::r% ir(k)it ff^fyfs'^k© 

* h£*U ktt 1 ~Nr <D8»"Cfc5 0 ar 

f±ggfrT'£><9, f c ( 1 M-f^T**** I (O-tfo-C 

ft^BS»"C*fe!K Kil-NcOlt-e$)5o Ic(l) 
^HV-T yf* 1 GD^— * bZ&'to acf« 
»t?*>9, f r (k)f*. if n£fcr±ff>r >ry^k(D 
BB»-CfeS. modNr ^it^nodNc fi, **L«ve^A 

^-y-y^ntf-^tvMi, wrt^ h y 

[0010] f c ( l )*5J;t/f r (k)S:, f c (l)=m 
l+[Nr + l]mod2 mteg^c-CfoO , Nr/ 

Nc Ki3«fc*:3SLV*) , f r ( k ) = 2 k + [N c + 1 ]mo 
d2(7)J;5l-IRU £fcar£r, Nr/log 2 (log 
2 (Nr )) J: 0**^****4: LTiitfurso^Sig 

*3*frt- 5 J: 9 «/£ $ *tfc u- h y + V ^t^r 

[0 0 11] r^W^ftfe^J®*!, NrfT*JJ:t/Nc 

try h*^*-y-:/^5;fr«s«:«6«i-*. 
-e, ^^-y-y^s^tx-^tr* mibt^s; 

[0 0 12] 

[&4] 

fT&^X. . I r (k) = [a r k + f c ( 1 )]modNr 
W&^Wz. Ic(l)=[ack+fr (k)]modNc 
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[0 0 13] I r ( k ) liff -f >X y ^ ^ k 60t^ 

— *tryh£r*U kfil~Nr ^T'O^^cT'feSo a 
r f*M$:T& «9 , fc(l)=ml+[Nr + l ]mod 2 11 

£>9, f r (k) = 2k + [Nc4- l]mod2T*£>£o mod 
2, modNr *3j;t/modNc te. ^ft-t'Jvev'a. a 2 % * 

D N r fc^^^a O N c f f ^Ht, 

j^?-v-7£tiitT-?vr>y Mi, ^ijrtic^ h y 

70 [0 0 14] rc!>*Mtt, r<D*ftS:jSEfTi-6«t 

[0 0 15] rc0^^Oft&<DfiWfi, ??^fc:$tL^x- 

^ try h$:H'Jl*-rsc<h^j:9, ttyra«**i&*flF* 

[ooi6] zco^Sste, x-y try httt»Jffl{cj|a 
y-^Sftfc-^y ^ h^^yf-f try hSrB'Ji* 

20 LXls— Y^y^^y*Wi&1rZ>*7 L y-7t*^ts 0 
[0 0 17] Z<DftW<D£btg:Z)Mmi:, »t'^fc 

-y-^Lti/-hv^ym^ii«o ^ 
^-y-^-r-s^^y^t, ^^-y-^^tufc^y 

50 [0 0 18] £ (b^z.<n$£Wte, z.tih<D^m^mrri- 
[00 19] $P>^roa5M«o«b^ttiJffi»i, 0 4 8:#ffi 
(shuffle) -f6*«fe, ^J:^2<i:^#v^- : e(DJ:9ft7 ^ 

h y-^ic^sro^&^^ftis^jc^-r 

So 

[0 0 2 0] I©8WOSe>45«ffilt — UK 
[0 0 2 1 ] 

^^/u . >f v*— y — tr>^gEfeicol»fi&^*ttr^ 

5o r ±^t-t^t^b*)QoS (if- 

-M.z&ttbx&mit'tz «fc9»frrsir-f * • 
^^tioms. s^o-r-^^f^ h y-A 
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^A^ff^A^ 1 4 £tb£ 0 r.coff^fi, 

tbb^A^ff-^-^, l 6 tCjo^TCRC (i&HJ 

7C*8«E) K3ft«f+*n**L, fiai^ + JM' • T&T-y 

ittb\c±?*> hftm&ti. is hik£ interna 

FECyn^^2 2C^^TFEC (ffir^RUIT 
IE) 4f^jt;*S*tS 0 ??#{t*tLfcfS#tt, ^/u^-Xu- 
W2 4K:tev*T#S{fc£*b£« 

[0 0 2 2] &M1k£ti1ti8 #f±, Xci 3,^ 2 6K3o^ 

oo^v^-r y >^ (gr]|&) Jfcttf*— (tr 
y h) <£>£«) tatt, x—^^— h£r, 10ms oft 5 

Kair rate)) iCigltt'y 

gi^y^-yw<2 SKte^T^i^—y — X£*t 

6 0 ^<2 8fi, ttlWlOms 

y s<tm*£tiz>o ai-eii, ^>*-y— '<2 

8111/- h-7->fyi/(73yp 2 6^»< t><£><i: Lt 
y— 2 8l£{fcii&£*U ^y^-y-/<^p>M 

^-y-ysn^ff^isu-- hvy^yo ^2 
ju^b^c^y ^*^«#eai0>fc«&fc:Bi i (c^sn 

[0 0 2 3] %£g2 6*3j:r>*2 8IC«#, 3B*t 
Pt^YfcZfu 3 0*5<fct*3 2lCio^r, 

^■(1, fg2?M >-*-y-'<3 4tCctoTW>'^~y- 
y£ft6o i2W^-!)-/<3 4iOlil*ll % 8t*P^ 
*8Hc:fctt 5 C DM AfflaRiiftaK*^ LfciHf 



(5) *£H§ 2001-57521 

<? 

[0 0 2 4] ±lB#JBLfcWen TongM{c«t SttrtttiMtc 

fc t *tf£jLT»j:KKr £ £ e> ^ y >-^JSf^ 

tc£T\ g2W ^^-y-v<3 4£^i&£fcf±Sg/J>1- 
lv\ ^5-c&ttixtfm2<o-r>^ — y— ^< 

3 4fi, ttl^'iX(0^l(D^ y— v<2 8tCj:oT 

J:t>*Q o s\c^^xmmik1rZ>^kfcx%Z>frhXlh 
[0 0 2 5] Lf:^ot, % 1 <7M y — s< 2 8 

20 (linear congruential rule) ^r§:tt, >f y — fc" 

-rs^<t(cj;«9, *>c^-r>^— y — trv^ais^j: 

t^ffln (^^fA^/N'y (time span) ) ^S^t^ 

[0 0 2 6] WT<OlftWtt, ^ h y ^ X(DtT*5 i^iJS: 

iWSn^itfy hSr^^yffiR0PflTHB8lc»»-rSw^ 

[0 0 2 7] iEI^BBbfclfrWaiJB-ClEifiSttT^^J: 
[0.0 2 8] i. T—fVybcDn^ikZinizyvyf 

[0029] 2. ^To^:t-i4oT^ h y ^^COfT^J: 

[0 0 3 0] 
[IS5] 

50 t?cO^-<#^ I r (k) = [ar k + f c (1 )]modN r 
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^Jco^-<#x. I c ( 1 ) = [a c 1 + fr (k)]modNc 

[0 0 3 1 ] I r (k) ttfM >"T y?*k <D7* 

-^f^^tU k(il-Nr^IS-C$)5 0 aril 

ft&^mTL'tyt — tx-lhZo fc(i)ii 
?|J-T 1 c0iE^-C^>«9, 1 fil—Nc 

SERT-fc*. I c ( 1 )&¥W>'y*y?x 1 ^-r— * My 

$)5 0 f r (k)terf^ >-^y? *k(OJEM%tX*foZ> 0 mo 

dNr &J;tftT10dNc ft, ^^PNrfcct^^aDN 

[0 0 3 2 ] 3. ^hV?Xfrh^>'? — y--7'£tlfz 

[0033] i Srbf^iit, -^hy? 

^C-rsJ; k&X$Z> 0 tc.kz.tf. -^hy^* 

|N r /log 2 (log 2 (N r ))J 
[0 0 3 6 ] fig^C f c ( l)=m I + [N4- l]mod2T*&> 

*k cr-emtiJ^Tco^: (5) (cior^^tL^^^^ 

Li/^gcT-fc6 0 £fc, f r (k)= 2 k +[Nr 4- l]mo 

[N r /NT] 



LtgrS^f ys+3<Z>&Jite* 1$S 

= l kfofe-tZo 
[0 0 3 4] T-'T y~7 2 TMi, tT^^W^^^^ > — * a 

rfi, ETFoS; (3) -c*SixS»ct«9/h*v^***«: 

J^T<o« (4) -e**ttS*J:0/hSi^»***-e*>-6 

[0 0 3 5] 
[*6] 

^ (3) 

at (4) 

20 Xd2XhZ> 0 



[0 0 3 7] 
[£fr7] 



[0 0 3 8] [Nr + 1 ] mod2tt, Nr ^-SHSrCfe-S 
b^TfcS. *fc, [Nc + l]mod2H, Nc^ffSt 

flflbWifci. .tot, B8»f c (l )*3«tr/f r (k) 

^ii©SNr*fc|j:Nc*s|Plft 

[0 0 3 9] Jiia^^ Lfc £ 0 Id, Ix— h-ey^-l^ 
fi, "r—ffcmy I'—^W't X&MffiL? u~ M-W^ 

^y^ (HUBft) t5c *a?«-, ^-^fiis^i/- 

^r^oi^7u-A^tvNy^^t y V'^itfcfcfry 

[0040] miic^ztizxoizu-h^y^^yy 

* y? 2 6& s 7"Y*/\' • 4 ^?— ] Js<-2 8 {C5fetf L 
tvv5»4, B 2M^£n6 J; 9ftgE*acou— h^s^ 



[0 0 4 1] B2 Sr#fiS-r-5i:> ^ ht-fXN i 

50 0l:fc^t»y^y=N r -Ni <o J: 9 £>*x. 
y«\ 'Of 1 ? * y zs?ti*&9lb £*L*«^lcte-t?n J: 
(IE) x I y I tr* h<oR«#£J^iS*L6# 
*|if4<o J;9/h*< (A) ft So /O'^yJJ 

hSS (y<0, Ei v 20*^Jt^$tL5) (DXryy 
tt, (H2 0£{|iJ{w^^tL5/<>'^^^ y >^ (y>0) 

[0 0 4 2] y >0ft^f^, gS7U-^(DNr t** h 

e o s *Cfl]^t;$n, fif# r 1 «C?0JH{b*tL 

5o yD^^4 3M^t, r iNr *>if 5^J^f$ 
r^Nrft^f^, /n. 7 ^4 4iC^I / >te^f^2 
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7u y? 4 6{^^^XyO^^^ y v^Dry^ 
4 7 (C^o^T e (Di&tf 2 N r fcttit^n, tT^7 £ 
r fi^n y? 4 8{C4oV>T 1 fctfti^£*U ^Jl^n >y 
^ 4 3i-M6o 7*yi? 4 5 ^C4oV^-C e ^ 0 "CfttttLtf 
e>0) , ^th 

r>Nr) s :ftli7i/- i^S&*?9fcigLfc::<!:£^ 
[0 0 4 3 ] U&»L*a*&* l^-h^i/fy^yoy^ 

(c, ^-^a- • — y — \?><y%m<Dm*t \s— b 

[0 0 4 4] ft^.^fy^-y-t'y^i^t' 

utstiz^y bv>, mmxm^i,<mmit^titzi—b 

^y^*fs<*~-^v>W®r\±. frteVtemmts. H1z\* 
fcf^HiKT)-^ h y ^JX^ol^T, so-y-?-^ y >?&ti 

— (DU^(ciov>T^<>'^^^ y v^ns^^fc 
usi^^^mtst'^h^ ^o-^-y-tf 

— tr>^iw (Sfcii^ v*— y — t^^so cotfy h 

[0 0 4 5] 13 3 11. ^<Z>»M^*J£?Bffi^se5^^^ 
tv - — y — 2 8*5<tt/i^— % Y^v^^if m fxj 

-y-^2 8(t 2*»Six^*ffl^*y 5 OSrfll 

/c-^ h y ^^-e^^tb^Nr Nc of~^ h^fe^ 

t6 0 lilbOf-^fyMl h y y*<D?TmiL(D 
PNrfT*!?V^51lt * o ^^{S-^-C LKIOSSL 



(7) W200 1-5 7 5 2 1 

12 

Vis? 5 ico^^y— («r±tf) ttifcfi, ^J-Y^xy^ 

* i ^t^^F^iim^PNc <DWi<y> 

. & 5 2\zmm£tlZo *V>*5 1*S£X*5 2<D$$>' 

«Kfl«&3*L5. J: 0 ^^^5 3^ 

9>M1»JS«5 4*5«tt5 5 5ld«j(&S^ 11^5 4 

*L«*4*U, a c 1 *5cfctfm 1 *<H-«**iV«x£ril 
-f5 0 t?^^>^5 i©^?yHiSIg5 6*5 .to 5 5 

70 7|C«We*tL, **85 6*iJ;tf5 7|Ctt*fc, «« 2 
*5<tt/^7^-^ a r tf^il^tltoteiStl* 2k*5j;t>' 
a r k -ttb-fiXfefiic-r So *n3?££5 8 fct, * 

p n c 9 , ±mc®,w ^tcm®-^wx-mm* . 

MM l, n r as«»avfr#jwc#ff Lr-ttt-en 1 *yt 

o>r y — y^ns>— ^-^^{-^tts^^Ho 
^ tr^ h£^y 5 o^b^m-Tfc^^r 

30 [0 0 4 6] ^TN r 0>»J&S2<BR*T*fc*fce>tf, T K 

[0 0 4 7] Nc <OSIRfflPt?tt*l>ffi«01^-<X(D7 U 
— J»<Dt — ? ¥y b&4 >"? — V—y*-tZ><Dfrmi£ 

i^fc^o h y ?*<Drrmz. <<^$- 

^t^) (D^^e])i\Lmnm^^^.thx^^j:^\ -op — v 

-y&tlZT—f ¥y bfrhZtlb<Djt*})GLWi<?>T-- 
^t'yF^^T^fc^ m3co^>^— y — ^^2 8 

o^rn^^ey 5 oa^^— ^^tt^tusns wtSrBS 
c^9, ^^7f63^i< 0 ^^-y 5 oa>p>>f v^ — 

50 y— y&tllZT— 9¥y bcD—feco^r — y-ttit} i — h£ 



(8) 

13 

W-te-tZtzib. & 3 <D ^ I"? — ]) — y< 2 8 F I 

FO (^feAtu5fet±3L) ;*^y 6 5£ffij;i x FIFO^ 

ttSixS, FIF06 5H tMHWV^-!) -f 

[004 8] 6_h<7)^ — y — 7£tltzT— 10 

— h^s/^V^ ■ T V\s* J £$L%*7 0 <b x 7K^«t 
fStt£(57 3, fcfcl&H? 7 4$3£TJ7 4 > 7 6 ±{d W— K t 

Mli^?riM5F I F0 6 5(Dm^tmm 
\£ s ^h-e^fy«2 6t, F I F O ££:tefdlO 20 
/<V7T m^iti*) '^tlt, ffi^7^>7 6?)^- 

[0 0 4 9] U— h-^^^Vi/ • T KUX^§§7 0 

-tr^u- * 7 l tcJ:or±{iL^^oJ:t> # Tffi^^^^ 

3§7 otcj:oTr try hott3^^fflm«c±ffitr y 
tt, 7 0HO7 K^*Nr t»*Lt, 

t/*9#, 7K^--fe/U — * 7 lcD2o<7)ffi;>j£«t 
[0 0 5 01 T KU^'fg-^7 2(2, 7K^|f^5 

3 1 iz&commzmrf-t %a ±mcmLiz£?^ 40 
vblw-tz - y - tr > ^/^s^ tf, 

>*-y-'<— -r>'^-y-^<6omjt<t^:< 

3§7 2£, 7 K^fffgS 3 t±< l^i:tOCt5w 
Ifc^ot, T K!/^I^7 2<Z>SM»fc 
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[0 0 5 1 ] 7 Kl^^S^7 2(Dm^HlS1S^7 3tC 
/<77 7 ^, IS1SS&7 3^5>©/<!/7 7 ZfrtlttiJj 

2 8 5 1 & &Xf9H*&>? 5 2^S^ 
RlS^feS^Stt. V7 7±Ul^fcftafrb;h/fc#ffi 

7±jc^*4x5. -to«^B*tt, y >^ 

h&m.i>£tite\,^t**y h-o^t, >7 7.±o$ijp 

3 0^^9^(7)1/1/^(7) 1 o (|213fC^^tl5) 
mSZtlZ?^ >-6 6^P>(Ofcf ^ b&ftti?^ ^7 6tC 
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1 . A method of matching a rate of data bits, in a matrix of data bits interleaved by a 
predetermined interleaving process, to a desired rate by deletion of redundant data bits or 
repetition of data bits derived from the matrix, including the steps of: 

determining in a non-interleaved matrix of said data bits a pattern of bits to be 
deleted or repeated to provide said desired data rate; 

decoding an address of each bit in said pattern in a manner inverse to the 
interleaving process to produce a respective address of the bit in the matrix of interleaved 
data bits; and 

deleting or repeating the respective bit in the interleaved data bits in dependence 
upon the respective address. 

2. A method as claimed in claim 1 wherein the address decoding is performed in the 
same manner as a coding of addresses for producing the interleaved data bits from the 
non-interleaved matrix of said data bits. 

3 . A method as claimed in claim 1 or 2 wherein the pattern of bits to be deleted or 
repeated is dependent upon the number of bits to be deleted or repeated and a column 
index of the matrix. 

4. A method as claimed in claim 1, 2, or 3 wherein the interleaving process 
comprises permuting rows and columns of a matrix of N r rows and N c columns, in which 
data bits to be interleaved are represented row by row, in accordance with: 

Row Permutation I^k) = [o^k + f c 0)]modN r 

Column Permutation ^(1) = [a^l + f r (k)]modN c 
where 1,4k) represents a data bit with a row index k, k is an integer from 1 to N r> a, is an 
integer, f c (l) is a non-zero function of a column index 1, 1 is an integer from 1 to N c , ^(1) 
represents a data bit with the column index 1, is an integer, f r (k) is zero or a function of 
the row index k, and modN r and modN c represent modulo-N r and moduJo-N c arithmetic 
respectively, interleaved data bits being derived from the matrix column by column. 

5 . A method as claimed in claim 4 wherein f c (l) = ml + [N r + 1 ]rnod2, where m is an 
integer. 

6 . A method as claimed in claim 5 wherein m is approximately equal to N r / N c . 

7 . A method as claimed in claim 4, 5 or 6 wherein f r (k) = 2k + [N c + 1 Jmod2. 

8 . A method as claimed in any of claims 4 to 7 wherein a? is the largest prime 
number less than N r / log 2 (log 2 (N r )). 
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9 . Rate matching apparatus arranged for carrying out a method as claimed any of 
claims 1 to 8. 

10. A method of interleaving data bits comprising permuting rows and columns of a 
matrix of N r rows and N c columns, in which data bits to be interleaved are represented 
row by row, in accordance with: 

Row Permutation 1^) = [ctjJc + f c (l)]modN r 

Column Permutation ^(1) = [c^l + f,(k)]modN c 
where I r (k) represents a data bit with a row index k, k is an integer from 1 to N p 04. is an 
integer, f c (l) » ml + (N r + l]mod2 is a non-zero function of a column index 1, 1 is an 
integer from 1 to N c , m is an integer, I c (l) represents a data bit with the column index 1, 
is an integer, f T (k) = 2k + [N c + 1 Jmod2, and mod2, modN r and modN c represent 
modulo-2, modulo-N n and modulo-N c arithmetic respectively, interleaved data bits being 
derived from the matrix column by column. 

11. A method as claimed in claim 10 wherein m is approximately equal to N r / N c . 

12. A method as claimed in any of claim 10 or 1 1 wherein ctr is the largest prime 
number less than N r / log 2 (log 2 (N r )). 

13. A data interleaver arranged for carrying out the method of claim 1 0, 1 1 , or 1 2. 

14. A method of interleaving and rate matching parallel concatenated convolution^ 
coded data by deletion of coded data bits, the coded data bits comprising systematic bits 
and parity bits, including the steps of interleaving the systematic bits separately from the 
parity bits, and deleting parity bits from the interleaved parity bits to provide the rate 
matching. 

15. A method of interleaving and rate matching parallel concatenated convolutional 
coded data by repetition of coded data bits, the coded data bits comprising systematic bits 
and parity bits, including the steps of interleaving the systematic bits separately from the 
parity bits, and repeating parity bits of the interleaved parity bits with a greater repetition 
factor than any repetition of systematic bits of the interleaved systematic bits, to provide 
the rate matching. 

1 6. Coding, interleaving, and rate matching apparatus arranged to carry out the method 
of claim 14 or 15. 

17. A method or apparatus generally, substantially, or essentially as described herein 
with reference to any one or more of Figs. 3 to 5 of the accompanying drawings. 



3. Detailed Description of Invention 
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This invention relates to rate matching and channel interleaving for a 
communications system. 
Background of the Invention 

It is well known to perform interleaving of data in a communications system using 
forward error correction (FEC) in order, on deinterleaving, to distribute errors to facilitate 
their correction. Typically, such interleaving uses a block interleaver to interleave blocks 
of data. So-called turbo coding (parallel concatenated convolutional coding) uses an 
interleaver between inputs to two convolutional coders which produce respective parity 
bits from the input data before and after interleaving. With increasing attention being 
given to the use of turbo coding, particularly in wireless communications systems, 
attention has also been given to the form of the interleaver. 

So-called 3rd generation CDMA (code division multiple access) wireless 
communications systems are also being developed which require a channel or inter-frame 
interleaver which operates to interleave or permute data in blocks corresponding to the 
radio frame duration, typically 10 ms. In such systems the channel interleaver either 
precedes or follows a rate matching function which serves to match various data rates to 
the radio frame rate, and which typically involves puncturing (omission) or repetition of 
data symbols, in this case data bits. It is desirable to distribute the omitted or repeated bits 
as evenly as possible, with as great a distance as possible between punctured or repeated 
bits in the de-interleaved frames, in a manner that is easy to implement and that is 
relatively independent of variables such as the frame size, number of frames, and 
puncturing rate. 

Canadian patent application No. (File 10378RO) filed March 19, 1999 in the 
names of Wen Tong et al., entitled "Data Interleaver And Method Of Interleaving Data", 
describes and claims a method of interleaving data and a data interleaver which 
advantageously can be used to provide the channel interleaving referred to above. The 
present invention is concerned with rate matching in a manner which can be used with 
particular advantage for data after such channel interleaving, but which is also applicable 
to other forms of interleaved data. This invention also provides improvements in and 
further applications of such channel interleaving. 
Surnrnary of the Jhyentiqn 

According to one aspect, this invention provides a method of matching a rate of 
data bits, in a matrix of data bits interleaved by a predetermined interleaving process, to a 
desired rate by deletion of redundant data bits or repetition of data bits derived from the 
matrix, including the steps of: determining in a non-interleaved matrix of said data bits a 
pattern of bits to be deleted or repeated to provide said desired data rate; decoding an 
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address of each bit in said pattern in a manner inverse to the interleaving process to 
produce a respective address of the bit in the matrix of interleaved data bits; and deleting or 
repeating the respective bit in the interleaved data bits in dependenc upon the respective 
address. 

It is particularly advantageous, and may be necessary in practice, for the address 
decoding to be performed in the same manner as a coding of addresses for producing the 
interleaved data bits from the non-interleaved matrix of said data bits. This is facilitated in 
preferred embodiments of the method of the invention by the interleaving process 
comprising permuting rows and columns of a matrix of N r rows and N c columns, in 
which data bits to be interleaved are represented row by row, in accordance with: 
Row Permutation l/k) = [c^k + f c (l)JmodN r 
Column Permutation ^(1) = [0^1 + f r (k)]modN c 
where I^k) represents a data bit with a row index k, k is an integer from 1 to N r , ot, is an 
integer, f c (l) is a non-zero function of a column index 1, 1 is an integer from 1 to N c , ^(1) 
represents a data bit with the column index 1, a c is an integer, f r (k) is zero or a function of 
the row index 3c, and modN r and modN c represent modulo-N f and modulo-N c arithmetic 
respectively, interleaved data bits being derived from the matrix column by column. 

It is currently considered optimum to choose f c (l) = ml + [N r + 1 J mod 2, where m 
is an integer, m approximately equal to N r / N c , f r (k) = 2k + [N c + l]mod2. and a, as the 
largest prime number less than N r / log 2 0<>g2( N r))* 

The invention also provides rate matching apparatus arranged for carrying out a 
method as recited above. 

Another aspect of this invention provides a method of interleaving data bits 
comprising permuting rows and columns of a matrix of N r rows and N c columns, in 
which data bits to be interleaved are represented row by row, in accordance with: 
Row Permutation 1^) = [o^k + f c (l)]modN r 
Column Permutation ^(1) = [o^l + f r (k)]modN c 
where I^k) represents a data bit with a row index k, k is an integer from 1 to N r> is an 
integer, f c (l) = ml + [N r + l]mod2 is a non-zero function of a column index 1, 1 is an 
integer from 1 to N c , m is an integer, !<.(!) represents a data bit with the column index I, 
is an integer, f/k) = 2k + [N c + 1 ]mod2, and mod2, modN r and modN c represent 
modulo-2, modulo-N r , and modulo-N c arithmetic respectively, interleaved data bits being 
derived from the matrix column by column. 

The invention also provides a data interleaver arranged for carrying out this 
method. 

Another aspect of the invention provides a method of interleaving and rate 
matching parallel concatenated convolutional coded data by deletion of coded data bits, the 
coded data bits comprising systematic bits and parity bits, including the steps of 
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interleaving the systematic bits separately from the parity bits, and deleting parity bits from 
the interleaved parity bits to provide the rate matching. 

A further aspect of the invention provides a method of interleaving and rat 
matching parallel concatenated convolutional coded data by repetition of coded data bits, 
the coded data bits comprising systematic bits and parity bits, including the steps of 
interleaving the systematic bits separately from the parity bits, and repeating parity bits of 
the interleaved parity bits with a greater repetition factor than any repetition of systematic 
bits of the interleaved systematic bits, to provide the rate matching. 

The invention further provides coding, interleaving, and rate matching apparatus 
arranged to carry out these methods. 

Yet another aspect of this invention relates to a method of shuffling interleaved and 
rate matched data streams in the manner described below with reference to Fig. 4 of the 
drawings, and to the recursive application of this method to more than two such data 
streams. 

Further aspects of the invention relate to a method or apparatus generally, 
substantially, or essentially as described below with reference to any one or more of 
Figs. 3 to 5 of the drawings. 

Detailed Description 

Referring to Fig. 1 , there is illustrated a known arrangement for service 
multiplexing and channel interleaving in a 3rd generation CDMA radio communications 
system. The arrangement includes a service multiplexer 10 which serves to multiplex 
together a plurality of data signal streams, referred to as main stream services or QoS 
(Quality of Service) channels, which are supplied via respective service blocks 12 only 
one of which is illustrated. Each service block 12 is supplied at inputs 14 with a plurality 
of constituent input signals, which may for example comprise any of various types of 
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signals such as voice, data, and multi-media signals. These input signals may have 
arbitrary transmission rates, frame sizes, and other parameters. The input signals have 
CRC (cyclic redundancy check) codes added in blocks 16 and are multiplexed together in 
a transport channel multiplexer 18. The multiplexed signals arc segmented, for encoding, 
in a segmentation block 20, and the segmented signals are subjected to EEC (forward 
error correction) coding in FEC blocks 22. The encoded signals are multiplexed in a 
multiplexer 24. 

The multiplexed signals are subjected to rate matching (puncturing (deletion) of 
redundant data symbols (bits) or repetition of data symbols (bits)) in a block 26 to match 
the data rate to the radio communications rate (air rate) with radio frames of 10 ms 
duration. Primarily in order to separate adjacent bits to reduce the adverse effects of errors 
due to fading in the radio channel, the data bits are interleaved in a first intcrleaver 28, 
which is referred to as a channel or inter-frame interleaver because it operates to permute 
blocks each of 10 ms of data bits. Although in Fig. 1 the interleaver 28 is shown 
following the rate matching block 26, as discussed further below the positions of these 
functions may be interchanged, the multiplexed signals from the multiplexer 24 being 
supplied to the channel interleaver 28, and the interleaved signals from the interleaver 
being supplied to the rate matching block 26. For example, these functions may be in the 
order shown in Fig. 1 for downlink transmission of signals from a central station, and 
may be in the reversed order for uplink transmission of signals to the central station. 

FoDowing the functions 26 and 28, the resulting rate matched and interleaved 
signals are segmented for radio frames and physical channels in segmentation blocks 30 
and 32 respectively to produce the signals for multiplexing by the multiplexer 10. Signals 
output by the multiplexer 10 are interleaved by a second interleaver 34 the outputs of 
which are segmented and mapped to dedicated physical channels in a segmentation and 
mapping block 36 for communications via a CDMA radio communications path in known 
manner. 

As described in the patent application by Wen Tong et al. referred to above, the 
first interleaver 28 can have a performance that is sufficiendy good to enable the second 
interleaver 34 to be omitted or reduced to a simple shuffling operation, for example as 
described below. This is desirable in particular because otherwise the second interleaver 
34 has the potential to degrade the interleaving performed by each first interleaver 28, 
whereas each first interleaver 28 can be optimized for its particular rate matched data 
stream and QoS. 

Accordingly, the first interleaver 28 is implemented as an algebraic interleaver 
providing a good random spreading property. The multiple encoded bit blocks or data 
transport frames for each QoS channel are mapped into a 2 -dimensional matrix and are 
subjected to linear congruential rules to permute the rows and columns of the matrix to 
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implement the interleaving function. A maximum interleaving depth and time span can be 
determined by searching a set of best parameters. The interieaver consequently has a 
relatively simple form without disadvantages of known interleave^, such as requiring 
large memory sizes for look-up tables or inadequately accommodating the rate matching 
function. 

Although the following description refers to rows and columns of a matrix, it 
should be understood that this is for convenience and clarity, that the rows and columns 
can be interchanged without changing the function of the interieaver, and that in practice 
and as described below the interieaver can operate by equivalent control of read or write 
addressing of memory locations of a linear memory in which data bits are stored, without 
any actual movement of the stored bits among the memory locations. 

The interieaver 26 as described in the patent application referred to above operates 
to implement the following three steps: 

1 . Represent a number N c of encoded blocks of data bits each of length N r data bits 
as a matrix of N r rows and N c columns. 

2 . Permute the rows and columns of the matrix in accordance with: 

Row Permutation I^k) = [ctjk + f c (l)]modN r 

Column Permutation I c (l) = [c^l + t^.(k)]modN c 
where ^(k) represents a data bit with a row index k, k is an integer from I to N r , a,, is a 
row permutation parameter and is an integer, f c (l) is a positive function of a column index 
1, 1 is an integer from 1 to N Ct ^(1) represents a data bit with the column index 1, is a 
column permutation parameter and is an integer, f r (k) is a positive function of the row 
index k, and modN r and modN c represent modulo-N r and modulo-N c arithmetic 
respectively. 

3 . Derive interleaved data bits from the matrix column by column. 

Step 1 can be slightly modified to accommodate different numbers of data 
transport frames with a given number of columns of the matrix. For example the matrix 
can have N c = 8 columns for N c / y data transport frames where y - 1 , 2, 4, or 8, the 
matrix having N r / y rows accordingly, with a consequent modification of step 3 to read 
out y columns of the matrix per radio frame accordingly. For simplicity in the description 
below, it is assumed that y= 1 with N c - 8. 

For step 2, the row permutation parameter is chosen to be the largest prime 
number less than LN r / log 2 0og 2 (N r ))J, the column permutation parameter o^ is chosen to 
be the largest prime number less than l_N c _L the function f c (l) = ml + [N r + 1 Jmod2, where 
m is an integer equal to TN r / N c l, and the function f^k) = 2k + [N c + l]mod2. The 
symbols L J refer to rounding down to an integer, and the symbols [ 1 refer to rounding 
up to an integer. It can be appreciated that [N r + l]mod2 is zero when N r is odd and is 
one when N r is even, and that (N c + l]raod2 is zero when N c is odd and is one when N c 
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is even, so that ih se parts of the functions f c (l) and f^k) are simply the addition of one 
when the respective number N r or N c is ven. 

As indicated above, the rate matching punctures (deletes) redundant data bits 
(which are present as a result of the FEC encoding blocks 22 in the event that the data 
transport frame size is larger than the radio frame size, a maximum puncturing ratio being 
20% of the transport frame size. . Conversely, if the data transport frame size is smaller 
than the radio frame size, bits of the transport frame are repeated to achieve the rate 
matching. The rate matching is desired as far as possible to maximize the separation 
distances between the punctured bits and to equalize the number of punctured bits in each 
radio frame, i.e. to distribute the punctured bits uniformly among the radio frames with 
maximum separation. 

In the case where the rate matching block 26 precedes the channel interleaver 28 as 
shown in Fig. 1, a known rate matching method as shown in Fig. 2 can be used. 

Referring to Fig. 2, for each radio frame of segmentation size Nj bits, in a block 
40 an iutcger y is determined as y = N r - N is y being greater than zero (positive) in the 
event that puncturing is required, being less than zero (negative) in the event that repetition 
of I y I bits is required, and being zero if no puncturing or repetition is required, a stop 
block 41 being reached in the latter event. As the steps shown in Fig. 2 are substantially 
the same for bit repetition (y < 0, shown at the right in Fig. 2) as for puncturing (y > 0, 
shown at the left in Fig. 2, except for the use of I y I and repetition instead of y and 
puncturing, only the case of puncturing is described in detail below. 

If y > 0, puncturing of y of the N r bits of the transport frame is required to 
produce the Nj bits of the radio frame. In this case in a block 42 a parameter e is 
initialized to a starting offset which is determined in any desired manner for the 
particular radio frame, and a row counter r is initialized to 1 . In a block 43, it is 
determined whether r < N r and, if so, in a block 44 the value of e is reduced by 2y. In a 
subsequent decision block 45 it is determined whether e £ 0, and if so the bit in the row r 
is punctured at a block 46, the value of e is increased by 2N r in a block 47, the row 
counter r is increased by 1 in a block 48, and a return is made to the decision block 43. A 
negative decision at the block 45 (i.e. e > 0) results in a return to the block 43 via the 
block 48 to increment the row counter r without any puncturing or change in the value of 
e. A negative decision at the block 43 (i.e. r > N r ) indicates that the end of the frame has 
been reached, and accordingly the sequence ends at the stop block 41. 

However, in the case where the rate matching block 26 follows the channel 
interleaver 28, the rate matching is carried out on the permuted (interleaved) bit stream and 
the problem of rate matching is considerably more complicated. Generally, the 
requirements of the channel interleaving and rate matching processes are not consistent. 
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More particularly, the design of an appropriate, and desirably optimized, rate 
matching pattern of punctured or repeated bits within the matrix of bits after the channel 
interleaving process represents a v ry complex or impractical task. This invention avoids 
this problem by providing an appropriate, and desirably optimized, rate matching pattern 
of punctured or repeated bits for the matrix before interleaving, and to use a de- 
interleaving or decoding process to determine corresponding bits to be punctured or 
repeated at the output of the channel interleaves This process is facilitated by the fact that 
the de-interleaving, or decoding, process can be implemented by exactly the same 
structure as the interleaving process, as further described below. For convenience and 
clarity, the following description refers to the matrix of bits before interleaving (or after 
de-interleaving) as the natural matrix NM, and to the matrix of bits after interleaving as the 
randomized matrix RM. 

Fig. 3 illustrates an implementation of a channel interleaver 28 and rate matching 
block 26 in accordance with an embodiment of this invention. As illustrated in Fig. 3, the 
interleaver 26 includes a working memory 50 with two halves, alternately used in known 
manner for writing into and reading from the memory, each for storing the data bits 
represented in the matrix as described above, these data bits being written into the memory 
linearly corresponding to the row-by-row organization of the matrix. A modulo-N r row 
counter 5 1 is responsive to a clock signal CLK to provide, a count representing the row 
index k, and a carry output of this counter 5 1 is supplied to a modulo-N c column counter 
52 to provide a count representing the column index 1. The counts k and 1 of the counters 
51 and 52 are supplied to an address encoder 53 shown within a dashed line box in Fig. 
3. More specifically, the count of the column counter 53 is supplied to multipliers 54 and 
55 which arc also supplied with the parameters and m respectively to produce products 
representing o^l and ml respectively, and the count of the row counter 51 is supplied to 
multipliers 56 and 57 which are also supplied with the integer 2 and the parameter Oj. 
respectively to produce products representing 2k and o^k respectively. An adder 58 adds 
the outputs of the multipliers 54 and 56 and selectively adds 1 or 0 depending upon 
whether N c is even or odd respectively, and the output of the adder 58 is reduced to 
modulo-N c form by a modulo function 59 to complete the column permutation function 
described above. An adder 60 adds the outputs of the multipliers 55 and 57 and 
selectively adds 1 or 0 depending upon whether N r is even or odd respectively, and the 
output of the adder 60 is reduced to modulo-N r form by a modulo function 61 to complete 
the row permutation function described above. Each of the modulo functions 59 and 61 
can comprise comparison and subtraction functions. Outputs of the functions 59 and 61 
are combined in a read address combiner 62 to produce an address for reading the 
respective data bit in its interleaved sequence from the memory 50. As illustrated in Fig. 
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3, the read address is supplied to the memory 50 via a switch 63 which is pr vided as 
described below. 

If the number of rows N r is a power of two, then the address combiner 62 can 
simply combine the output of the modulo function 61 as the least significant bits, and the 
output of the modulo function 59 as the most significant bits, of the read address for the 
memory 50; equivalently the output of the function 61 is added by the address combiner 
62 to N r times the output of the function 59. 

It may be desired to interleave data bits in arbitrary-sized frames that are not an 
integer multiple of N c . In this case, the number of rows of the matrix is selected to 
accommodate all of the data bits to be interleaved, and the last few (less than N c ) memory 
locations in the working memory 50 ace not written into. In order to omit the data bits of 
these memory locations from the interleaved data bits, the interleaver 28 of Fig. 3 also 
includes a decoder 64 which detects these memory locations in the read address output of 
the address combiner 62, and upon such detection opens the switch 63 to prevent reading 
of data from the memory 50 in respect of these locations. In order to provide a constant 
data output rate of the interleaved data bits from the memory 50, the interleaver 28 of Fig. 
3 further includes a FIFO (first-in. first-out) memory 65, clocked by the clock signal 
CLK> via which the interleaved data bits arc supplied to an output line 66 of the 
interleaver, the FIFO 65 being pre-filled at the start of each interleaving operation and 
having a size (e.g. up to N c ) sufficient to allow for the non-read, and hence omitted, 
memory locations. 

The interleaved data bits on the line 66 are supplied to the rate matching block or 
function 26 also illustrated in Fig. 3. This rate matching function comprises a rate 
matching address generator 70 which is also supplied with the clock signal CLK, an 
address separator 71 , an address decoder 72, a buffer or store 73, comparators 74, and a 
data bit selector 75 providing a rate matched data output on a line 76. Similarly to the 
provision of the FIFO 65 for providing a constant data bit rate output of the interleaver 28, 
the rate matching function 26 may also include a FIFO or other buffer (not shown) for 
providing a constant rate of data bits from the output line 76. 

The rate matching address generator 70 generates at its output, as described further 
below, the address in the natural matrix NM of each punctured or repeated bit in 
accordance with the puncturing or repetition pattern which is determined for this process. 
This address is separated into most significant and least significant components by the 
address separator 71, whose operation is inverse to that of the read address combiner 62 
described above. Thus if the number of rows N r is a power of two, then the address 
separator 71 can simply separate the address bits output by the generator 70 into most 
significant bits and least significant bits; equivalently the address from the generator 70 is 
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divided by N r to produce an integer quotient and a remainder which constitute the two 
outputs of th address separator 7 1 . 

The address decoder 72 performs the inverse function of the address encoder 53. 
As indicated above, with the algebraic interleaving process described herein the structure 
of the de-interleaver can be exactly the same as the structure of Ac interleave^ and 
coirespondingly the address decoder 72 is exactly the same as the address encoder 53. 
Accordingly, the detailed structure of the address decoder 72 is not illustrated in Fig- 3, it 
being identical to the structure of the address encoder 53 as shown in Fig. 3. It can be 
appreciated that this same-structure characteristic of the complementary operations for 
interleaving and de-interleaving provides a substantial advantage and simplification in 
implementing these functions. 

The outputs of the address decoder 72 are buffered in the store 73 f and the 
buffered outputs from the store are compared in the comparators 74 with the current 
counts k and 1 of the row counter 5 1 and column counter 52 respectively of the channel 
interleaver 28, to provide a selector control signal on a line 77 with a predetermined state 
when the compared values are the same. The selector control signal is thus produced on 
the line 77 with this state at each time that a bit on the line 66 is to be punctured or 
repeated. At other times, for bits which are not punctured or repeated, the control signal 
on the line 77 controls the selector 75 to supply to its output line 76, synchronously as 
determined by the clock signal CLK, a bit from the line 66 supplied to a middle one (as 
shown in Fig. 3) of three inputs of the selector 75. At the time of each bit to be repeated 
or punctured, the control signal on the line 77 instead controls the selector 75 to supply to 
its output line a bit from either its upper input or its lower input (as shown in Fig. 3), 
depending upon whether bits are to be repeated or punctured respectively, as determined 
by a further control input P/R to the selector 75. The upper input of the selector 75 is 
connected to the output line 76 to provide for bit repetition, and the lower input of the 
selector 75 is illustrated as having no connection to provide for bit puncturing. As 
indicated above, a constant output data bit rate for the interleaved and rate matched data 
bits is provided by a buffer (not shown) to which data bits on the output line 76 are 
supplied. 

Because of the address decoding provided by the decoder 72 in the rate matching 
function 26, the rate matching address generator 70 can simply determine the desired 
pattern of punctured or repeated bits in terms of the normal matrix addresses in the manner 
described above with reference to Fig. 2, using the single parameter e os determined in a 
desired manner to optimize this pattern. For example, this parameter could be determined 
by an equation such as e os = [2py + 1 ]mod2N p where as described above y is the number 
of bits to be punctured or repeated for each column of the matrix, and p is a column index 
from 0 to 7 (for the case of N c = 8). 



m 

(25) mm 2001-57521 

This example, with interleaving as d scribed above of 8 data transport frames each 
of 10 bits, and requiring a maximum puncturing ratio of 20% to produce channel 
interleaved and rate matched radio frames ach of 8 bits ( a total of 16 out of 80 bits being 
punctured or deleted), is further illustrated by the following Tables 1, 2, and 3. Thus 
N c a 8 and N r = 10. Table 1 illustrates entry of the 80 data bits, numbered 0 to 79, row 
by row in a 10 by 8 natural matrix with the row index k from 1 to 10 and the column 
index 1 from 1 to 8: 
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The channel interleaving as described above produces a randomized matrix as 
shown by the following Table 2: 
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Hie rate matching as described above then punctures 16 bits, 2 from each column 
of th randomized matrix, in a pattern produced by the rate matching algorithm to give a 
punctured randomized matrix as shown by the following Table 3: 
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The channel interleaved and rate matched data bits are derived column by column 
from Table 3, i.e., with the order [ 57. 35, 51, 7, 67, 40, 26, 4 ]. The punctured 
bits are 2, 9, 11, 16, 25, 29, 31, 32, 34, 38, 47, 54, 61, 64, 68, and 75, for which the 
maximum puncture distance is 9 (25 - 16) and the minimum puncture distance is 1 
(32 - 31); this small minimum puncture distance indicates that this particular example is 
not optimum, a Larger minimum puncture distance being desirable. It can be appreciated 
that numerous other determinations of the parameters, and in particular of the parameter 
e os , can be provided to optimize the puncturing process. 

As indicated above, it is desirable for operation of the second intcrlcaver 34 not to 
degrade the performance achieved as a result of the first interleaver 28, and to this end it is 
advantageous for the second intcrlcaver 34 to be reduced to a simple shuffling operation, 
which interleaves data streams with different QoS while retaining the spreading properties 
achieved by the first intcrlcaver 28 for each QoS data stream. 

Fig. 4 shows a flow chart of a bit shuffling algorithm which can be used 
advantageously to interleave bits of two data streams of interleaved radio frames provided, 
as described above from respective service blocks 12 provided via the service multiplexer 
10 in Fig. 1. Denoting one stream TQ t having frames of bits and a second stream TQ2 
having frames of N 2 bits, with Nj > N 2 , Fig. 4 illustrates how bits of the stream TQ 2 arc 
inserted into the stream TQj. 

Referring to Fig. 4, initially in a block 82 a parameter e is initialized to Nj and a 
counter r is initialized to 1. In a block 83, it is determined whether r < Nx and, if so, in a 
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block 84 the value of e is reduced by 2N 2 . In a subsequent decision block 85 it is 
determined whether e < 0, and if so at a block 86 the next bit in the stream TQ2 is inserted 
into the stream TQ t , the value of e is increased by 2N 1 in a block 87, the counter r is 
increased by 1 in a block 88. and a return is made to the decision block 83. A negative 
decision at the block 85 (i.e. e > 0) results in a return to the block 83 via the block 88 to 
increment the counter r without any bit insertion or change in the value of e. A negative 
decision at the block 83 (i.e. r > Nj) indicates that the end of the frame has been reached, 
and accordingly the sequence ends at a stop block 81. 

For more than two data streams, the same process is applied recursively for the 
successive data streams. It can be appreciated from the above description and the 
illustration in Fig. 4 that the steps of this process have a direct correlation with the steps of 
the puncturing and repetition processes of Fig. 2, so that implementation of this recursive 
shuffling process can be particularly convenient. 

As indicated above, the puncturing of bits to achieve the desired rate matching is 
applied to data bits which have redundancy due to the FEC encoding provided by the 
encoders 22. One preferred form of encoding is so-called turbo (parallel concatenated 
convolutional) coding, in which the encoded data bits comprise the input data bits 
themselves, referred to as systematic data bits S, and parity bits PI and P2 provided by 
convolutional coders operating on the input data bits and on interleaved input data bits. 
The parity bits PI and P2 are typically punctured within the turbo coder to provide a 
desired rate turbo coder. For encoders 22 constituted by turbo coders, it is necessary to 
ensure that the subsequent rate matching function 26 does not puncture any of the 
systematic bits S, but only the parity bits PI and/or P2. In the case of repetition, it has 
been determined that repetition of the parity bits PI and P2 by a factor of the order of 2 or 
3 times the repetition of the systematic bits S provides a performance gain. 

To these ends, Fig. 5 illustrates a modification of part of the arrangement of Fig. 1 
for channel interleaving and rate matching of data encoded by turbo coding. Referring to 
Fig. 5, a turbo coder constituting one of the FEC encoders 22 is shown within a dashed 
line box 90 and, as is well known, comprises a turbo code interleaver 91 which 
interleaves input data bits, and two convolutional coders 92 which operate on the input 
data bits before and after interleaving to produce parity bits PI and P2, the input data bits 
also being supplied to the coder outputs as systematic bits S. A puncturing block, not 
shown, may also be present to select only some of the parity bits PI and P2 for supply to 
the coder outputs. 

Instead of a single channel interleaver as described above, Fig. 5 illustrates that 
individual channel interleaves 93 are provided for the systematic bit stream and the parity 
bit stream. As shown in Fig. 5, there are three channel interleaves 93, but it can be 
appreciated that the streams of parity bits PI and P2 can be combined and interleaved 
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together, so that only two channel interleaves are provided, one for the systematic bit 
stream and the other for the parity bit stream. Further inputs to the channel interleaves 93 
in Fig. 5 indicate the multiplexing of systematic and parity bit streams, respectively, for 
multiple channels, corresponding to the multiplexer 24 in Fig. 1. 

The rate matching function, which follows the channel interleaves 94, is shown 
within a dashed line box 94. A puncturing function 95 is applied only to the channel- 
interleaved parity bit streams, whereas a repetition function 96 can be provided to the 
parity and systematic bit streams, a selector 97 being illustrated to couple the channel- 
interleaved bits accordingly. The puncturing and repetition can be as described above. It 
can be appreciated that the illustration in Fig. 5 in this respect is intended ^grammatically 
to represent the principle that puncturing is not applied to the systematic bits, rather than 
showing an actual implementation of the rate matching function. It can be appreciated, for 
example, that puncturing or repetition, as required, could be applied only to the parity bit 
streams to provide the desired rate matching, without any puncturing or repetition of the 
systematic bit stream. 

Although the above description refers to separate functions and units for the 
various processes described herein, it can be appreciated that these can in many cases be 
implemented using functions of one or more digital signal processors or other integrated 
circuits. 

Although particular embodiments and examples of the invention have been 
described above, it can be appreciated that numerous modifications, variations, and 
adaptations may be made without departing from the scope of the invention as defined in 
the claims. 

4 . B i i e f Description of Drawings 

The invention will be further understood from the following description with 
reference to the accompanying drawings, in which: 

Fig. 1 illustrates a known arrangement for service multiplexing and channel 
interleaving in a 3rd generation CDMA communications system; 

Fig. 2 is a flow chart relating to a known rate matching algorithm; 

Fig. 3 illustrates an implementation of an interleaver and a rate matching 
arrangement in accordance with an embodiment of this invention; 

Fig. 4, which is on the same sheet as Fig. 2, is a flow chart relating to shuffling 
for a second stage of interleaving in the arrangement of Fig. 1 ; and 

Fig. 5 illustrates a modification of part of the arrangement of Fig. 1 for channel 
interleaving and rate matching of data encoded by turbo (parallel concatenated 
convolutional) coding. 
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A method of and apparatus for matching a rate of data bits, in a matrix of data bits 
interleaved by a predetermined interleaving process, to a desired rate by deletion of redundant 
data bits or repetition of data bits derived from the matrix, includes steps of deterrnining in a 
non-interleaved matrix of the data bits a pattern of bits to be deleted or repeated to provide the 
desired data rate, decoding an address of each bit in said pattern in a manner inverse to the 
interleaving process to produce a respective address of the bit in the matrix of interleaved data 
bits, and deleting or repeating the respective bit in the interleaved data bits in dependence upon 
the respective address. The address decoding is performed in the same manner as a coding of 
addresses for producing the interleaved data bits from the non-intcrlcavcd matrix of the data 
bits. The specification also discloses an advantageous interleaving process for channel 
interleaving in a 3rd generation CDMA wireless communications system, a shuffling method 
for a second stage of interleaving in such a system, and how the rate matching can be . 
conveniently applied to turbo-coded data coded. 
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